## 1 Lab 1 - Introduction to FPGA's and VHDL

#### 1.1 Introduction

This lab will introduce you to the Altera DE2-115 FPGA Development Board. The DE2-115 contains all of the hardware necessary to prototype and create various hardware configurations on the Altera Cyclone IV FPGA chip that will be used throughout the course of this lab. By completeing this lab, you will have an understanding of all the hardware contained on the FPGA development board, along with an understanding of how to connect peripherals to the development board. Lastly, this lab will go over the standard template for designing hardware in the VHDL programming language. All this will be accomplished by following the Quartus II introductory packet along with the following activities.

#### 1.2 VHDL Basics

The following code block shows how to interact with the switches and LEDs on the DE2-115. Notice how the program begins with importing the ieee library which contains all of the basic logic primitives as established within the IEEE standard 1164. When working in industry it is common for large companies to create their own libraries as well. Every VHDL file should contain at least one entity (module) that is the same as the name of the file. An entity contains information about the structure of the module such as how many inputs/outputs (I/O) and what type of logic to expect at the I/O. Finally we define the entity in an architecture block, this section does the work on the hardware. As can be seen, this code is setting the red LEDs as defined in the array to the accompanying switches on the board. Take note on the use of comments throughout the code, comments begin with two dashes (–) and should always be used to describe what you are trying to accomplish, this way someone else who reads your code will understand it easily and your code will look more professional.

```
-- Import logic primitives
 1
 2
   LIBRARY ieee;
   USE ieee.std_logic_1164.all;
 3
 4
 5
   -- Simple module that connects the SW switches to the LEDR lights
   ENTITY lab1 IS
 6
   PORT (SW: IN STD_LOGIC_VECTOR(17 DOWNIO 0); -- Initialize switches as an input
 7
           LEDR: OUT STD_LOGIC_VECTOR(17 DOWNIO 0)); -- Initialize red LEDs as an output
8
   END lab1;
9
10
11
   — Define characteristics of the entity lab1
   ARCHITECTURE Behavior OF lab1 IS
12
13
   BEGIN
14
           LEDR <= SW; -- Assign each switch to one red LED
   END Behavior;
15
```

# 1.3 Activities

## **Implementing Logic**

Implement the hardware from the circuit in Figure 1. The inputs should come from SW[1] and SW[2] and the output should be shown on any of the available LEDs. Use the implemented circuit to test and create a truth table with your results and place it within a comment in the program file.



Figure 1: Circuit for activity 1

# 7-Segment Displays